草庐IT

Android SQLite 问题 - 表...没有名为的列

全部标签

ruby - 将 OpenStruct 与 ERB 结合使用时出现问题

编辑:忘记包含我的环境信息...Win7x64,RubyInstallerRubyv1.9.1-p378编辑2:刚刚更新到v1.9.1,补丁429,但仍然遇到同样的错误。编辑3:在Rubyv1.8.7补丁249中运行相同的代码,效果很好。所以显然是v1.9.1破坏了它。我是ERB的新手,我能找到的示例是……嗯……没什么用……在使用ERB大约一个小时后,我得到了一些基本示例(终于),但我不知道为什么这不起作用......require'ostruct'require'erb'data={:bar=>"bar"}vars=OpenStruct.new(data)template="foo"

ruby 文件::目录?问题

我对ruby​​还很陌生,但到目前为止我非常喜欢它。有些事情给我带来了一些麻烦,以下也不异常(exception)。我在这里尝试做的是通过子类化“Dir”来创建一种“super目录”。我添加了一个名为“subdirs”的方法,该方法旨在列出目录对象的文件,如果文件本身是一个目录,则将它们推送到一个数组中。问题是,我的测试结果(File.directory?)很奇怪-这是我的方法代码:defsubdirssubdirs=Array.newself.eachdo|x|puts"Evaluatingfile:#{x}"ifFile.directory?(x)puts"Thisfile(#{x

ruby - 有没有一种干净的方法来访问哈希数组中的哈希值?

在这段代码中:arr=[{id:1,body:'foo'},{id:2,body:'bar'},{id:3,body:'foobar'}]arr.map{|h|h[:id]}#=>[1,2,3]是否有更简洁的方法从这样的哈希数组中获取值?Underscore.jshaspluck,我想知道是否有Ruby等价物。 最佳答案 如果你不介意猴子修补,你可以自己动手:arr=[{id:1,body:'foo'},{id:2,body:'bar'},{id:3,body:'foobar'}]classArraydefpluck(key)map

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d

ruby - 在没有 ActiveRecord 的情况下为属性设置默认值的最佳方法?

我认为这个问题(Howtodoattr_accessor_with_defaultinruby?)回答了我的问题,但我没有使用ActiveRecord和after_initialize取决于它。为attr_accessor实现默认值的Ruby最佳实践是什么?是this最接近文档的东西是什么?我应该停止使用attr_accessor因为它是私有(private)的吗? 最佳答案 classFoo#class-levelinstancevariable#settinginitialvalue(optional)@class_var=42

ruby - 使用 RVM 在 Ubuntu 10.10 上安装 Ruby,gem 有问题

我决定从ubuntu10.10开始。我从安装git开始,然后从gitrepo安装rvm。一切正常很好,我编译并安装了ruby​​1.8.7和ruby​​1.9.2gem也已安装,我运行gem-v但是当运行gemlist或geminstallrake我得到以下错误ERROR:Loadingcommand:list(LoadError)nosuchfiletoload--zlibERROR:Whileexecutinggem...(NameError)uninitializedconstantGem::Commands::ListCommand知道如何解决这个问题吗?我也试过sudoapt

ruby - 如何在 ruby​​ 中读取没有 quote_char 的 CSV?

我有一个没有引号字符的TSV文件。每当数据中出现\t时,它总是分隔列,而不是列值的一部分。每当"出现时,它始终是列值的一部分,并且永远不会包含列值。我想用Ruby阅读这个CSV,但它给了我/Users/.rvm/rubies/ruby-1.9.3-p545/lib/ruby/1.9.1/csv.rb:1925:in`block(2levels)inshift':Illegalquotinginline9506.(CSV::MalformedCSVError)我的代码是:CSV.foreach(input_file,{:col_sep=>"\t",:headers=>true})do|r

ruby-on-rails - 没有路由匹配 { :controller= >"stocks", :action= >"create"} RSpec Rails 3

我不明白为什么我在运行RSpec时收到此错误消息:Failure/Error:post:createActionController::RoutingError:Noroutematches{:controller=>"stocks",:action=>"create"}controllerstocks存在,actioncreate存在,它应该使用的路由是这样的:match'stocks/:user_id'=>'stocks#create',:via=>:post,:as=>:query路由文件:FruthScreener::Application.routes.drawdoroot:

ruby - 有没有办法知道当前的 rake 任务?

是否有可能知道ruby​​中当前的rake任务:#Rakefiletask:installdoMyApp.somemethod(options)end#myapp.rbclassMyAppdefsomemetod(opts)##current_task?endend编辑我问的是任何可以查询的环境|全局变量,因为我想让应用程序智能化rake,而不是修改任务本身。我正在考虑让应用程序在由rake运行时表现不同。 最佳答案 这个问题已经被问过几个地方了,我认为没有一个答案很好......我认为答案是检查Rake.application.t

ruby-on-rails - Ruby on Rails : hash. 每个 {} 问题

这是我的代码:records_hash=records[:id].inject({}){|result,h|ifresult.has_key?(h)result[h]+=1elseresult[h]=1endresult}@test2=records_hash.each{|key,value|puts"#{key}is#{value}"}我的输出应该是这样的:bozois3bubbais4bonkeris5但它在页面()上呈现如下:bozo3bubba4bonker5我已经用类似的block尝试了.each_key和.each-value,它们都返回上面相同的字符串。我在IRB中运行相